home *** CD-ROM | disk | FTP | other *** search
/ HPAVC / HPAVC CD-ROM.iso / pc / SATAN11.ZIP / SRC / BOOT / BOOTPARA.X < prev    next >
Encoding:
Text File  |  1995-03-07  |  3.0 KB  |  101 lines

  1. /*
  2.  * Sun RPC is a product of Sun Microsystems, Inc. and is provided for
  3.  * unrestricted use provided that this legend is included on all tape
  4.  * media and as a part of the software program in whole or part.  Users
  5.  * may copy or modify Sun RPC without charge, but are not authorized
  6.  * to license or distribute it to anyone else except as part of a product or
  7.  * program developed by the user.
  8.  * 
  9.  * SUN RPC IS PROVIDED AS IS WITH NO WARRANTIES OF ANY KIND INCLUDING THE
  10.  * WARRANTIES OF DESIGN, MERCHANTIBILITY AND FITNESS FOR A PARTICULAR
  11.  * PURPOSE, OR ARISING FROM A COURSE OF DEALING, USAGE OR TRADE PRACTICE.
  12.  * 
  13.  * Sun RPC is provided with no support and without any obligation on the
  14.  * part of Sun Microsystems, Inc. to assist in its use, correction,
  15.  * modification or enhancement.
  16.  * 
  17.  * SUN MICROSYSTEMS, INC. SHALL HAVE NO LIABILITY WITH RESPECT TO THE
  18.  * INFRINGEMENT OF COPYRIGHTS, TRADE SECRETS OR ANY PATENTS BY SUN RPC
  19.  * OR ANY PART THEREOF.
  20.  * 
  21.  * In no event will Sun Microsystems, Inc. be liable for any lost revenue
  22.  * or profits or other special, indirect and consequential damages, even if
  23.  * Sun has been advised of the possibility of such damages.
  24.  * 
  25.  * Sun Microsystems, Inc.
  26.  * 2550 Garcia Avenue
  27.  * Mountain View, California  94043
  28.  */
  29.  
  30. /*
  31.  * RPC for bootparms service.
  32.  * There are two procedures:
  33.  *   WHOAMI takes a net address and returns a client name and also a
  34.  *    likely net address for routing
  35.  *   GETFILE takes a client name and file identifier and returns the
  36.  *    server name, server net address and pathname for the file.
  37.  *   file identifiers typically include root, swap, pub and dump
  38.  */
  39.  
  40. #ifdef RPC_HDR
  41. %#include <rpc/types.h>
  42. %#include <sys/time.h>
  43. %#include <sys/errno.h>
  44. %/*#include <nfs/nfs.h>*/
  45. #else
  46. %#ifndef lint
  47. %/*static char sccsid[] = "from: @(#)bootparam_prot.x 1.2 87/06/24 Copyr 1987 Sun Micro";*/
  48. %/*static char sccsid[] = "from: @(#)bootparam_prot.x    2.1 88/08/01 4.0 RPCSRC";*/
  49. %static char rcsid[] = "$Id: bootparam_prot.x,v 1.1 1994/08/04 19:01:44 wollman Exp $";
  50. %#endif /* not lint */
  51. #endif
  52.  
  53. const MAX_MACHINE_NAME  = 255;
  54. const MAX_PATH_LEN    = 1024;
  55. const MAX_FILEID    = 32;
  56. const IP_ADDR_TYPE    = 1;
  57.  
  58. typedef    string    bp_machine_name_t<MAX_MACHINE_NAME>;
  59. typedef    string    bp_path_t<MAX_PATH_LEN>;
  60. typedef    string    bp_fileid_t<MAX_FILEID>;
  61.  
  62. struct    ip_addr_t {
  63.     char    net;
  64.     char    host;
  65.     char    lh;
  66.     char    impno;
  67. };
  68.  
  69. union bp_address switch (int address_type) {
  70.     case IP_ADDR_TYPE:
  71.         ip_addr_t    ip_addr;
  72. };
  73.  
  74. struct bp_whoami_arg {
  75.     bp_address        client_address;
  76. };
  77.  
  78. struct bp_whoami_res {
  79.     bp_machine_name_t    client_name;
  80.     bp_machine_name_t    domain_name;
  81.     bp_address        router_address;
  82. };
  83.  
  84. struct bp_getfile_arg {
  85.     bp_machine_name_t    client_name;
  86.     bp_fileid_t        file_id;
  87. };
  88.     
  89. struct bp_getfile_res {
  90.     bp_machine_name_t    server_name;
  91.     bp_address        server_address;
  92.     bp_path_t        server_path;
  93. };
  94.  
  95. program BOOTPARAMPROG {
  96.     version BOOTPARAMVERS {
  97.         bp_whoami_res    BOOTPARAMPROC_WHOAMI(bp_whoami_arg) = 1;
  98.         bp_getfile_res    BOOTPARAMPROC_GETFILE(bp_getfile_arg) = 2;
  99.     } = 1;
  100. } = 100026;
  101.